package com.example.controller;

import com.example.common.Result;
import com.example.entity.Address;
import com.example.entity.HotBooks;
import com.example.entity.Model;
import com.example.service.HotBooksService;
import com.github.pagehelper.PageInfo;
import io.swagger.annotations.*;
import org.springframework.web.bind.annotation.*;

import javax.annotation.Resource;
import java.util.List;

/**
 * 热门书籍前端接口
 */
@RestController
@Api(value = "热点书籍", tags = {"热点书籍的增删改查"})
@RequestMapping("/hotbooks")
public class HotBooksController {

    @Resource
    private HotBooksService hotBooksService;

    /**
     * 新增
     */
    @ApiOperation(value = "增加热点书籍", notes = "返回是否成功")
    @PostMapping("/add")
    public Result add(@RequestBody HotBooks hotBooks) {
        hotBooksService.add(hotBooks);
        return Result.success();
    }

    /**
     * 删除
     */
    @ApiOperation(value = "删除热点书籍", notes = "返回是否成功")
    @ApiImplicitParams({
            @ApiImplicitParam(
                    name = "id",
                    value = "要删除的热点书籍id,如'1'"
            )
    })
    @DeleteMapping("/delete/{id}")
    public Result deleteById(@PathVariable Integer id) {
        hotBooksService.deleteById(id);
        return Result.success();
    }

    /**
     * 批量删除
     */
    @ApiOperation(value = "批量删除热点书籍", notes = "返回是否成功")
    @DeleteMapping("/delete/batch")
    public Result deleteBatch(@RequestBody List<Integer> ids) {
        hotBooksService.deleteBatch(ids);
        return Result.success();
    }

    /**
     * 修改
     */
    @ApiOperation(value = "更新热点书籍信息", notes = "返回是否成功")
    @PutMapping("/update")
    public Result updateById(@RequestBody HotBooks hotBooks) {
        hotBooksService.updateById(hotBooks);
        return Result.success();
    }

    /**
     * 根据ID查询
     */
    @ApiOperation(value = "通过id查询热点书籍信息", notes = "返回Models中的热点书籍信息类型")
    @ApiImplicitParams({
            @ApiImplicitParam(
                    name = "id",
                    value = "要查询的热点书籍id,如'1'"
            )
    })
    @ApiResponses({
            @ApiResponse(code = 200, message = "成功", response = HotBooks.class,reference = "HotBooks")
    })
    @GetMapping("/selectById/{id}")
    public Result selectById(@PathVariable Integer id) {
        HotBooks hotBooks = hotBooksService.selectById(id);
        return Result.success(hotBooks);
    }

    /**
     * 查询所有
     */
    @ApiOperation(value = "查询所有符合特征的热点书籍信息", notes = "返回Models中的热点书籍信息类型的数组")
    @ApiResponses({
            @ApiResponse(code = 200, message = "成功", response = HotBooks.class,reference = "HotBooks")
    })
    @GetMapping("/selectAll")
    public Result selectAll(HotBooks hotBooks ) {
        List<HotBooks> hotBooksList = hotBooksService.selectAll(hotBooks);
        return Result.success(hotBooksList);
    }

    /**
     * 分页查询
     */
    @ApiOperation(value = "分页查询所有符合特征的热点书籍信息", notes = "返回Models中的热点书籍信息的分页数组")
    @ApiImplicitParams({
            @ApiImplicitParam(
                    name = "pageNum",
                    value = "要查询的页码,默认为'1'"
            ),
            @ApiImplicitParam(
                    name = "pageSize",
                    value = "每页尺寸,默认为'10'"
            )
    })
    @ApiResponses({
            @ApiResponse(code = 200, message = "成功", response = HotBooks.class,reference = "HotBooks")
    })
    @GetMapping("/selectPage")
    public Result selectPage(HotBooks hotBooks,
                             @RequestParam(defaultValue = "1") Integer pageNum,
                             @RequestParam(defaultValue = "10") Integer pageSize) {
        PageInfo<HotBooks> pageInfo = hotBooksService.selectPage(hotBooks, pageNum, pageSize);
        return Result.success(pageInfo);
    }

}
